
    using System;
    using System.Collections.Generic;
    using System.Data.SqlClient;
    using ADL;
    using ADL.ProyectosTableAdapters;
    using AEL.APU;
    using BEL;
    
    namespace CEL.APU
    {
    /// <summary>
    /// Acceso a la base de datos
    /// Modulo:Proyectos 
    /// Tabla:Apu_Estructura_Varios
    /// </summary>
    public class DO_Apu_Estructura_Varios
    {
    #region Adapter
    private Apu_Estructura_VariosTableAdapter _Adapter;
    /// <summary>
    /// Acceso al Table Adapter de la capa ADL
    /// </summary>
    public Apu_Estructura_VariosTableAdapter Adapter
    {
    get
    {
    if (_Adapter == null)
    _Adapter = new Apu_Estructura_VariosTableAdapter();
     return _Adapter;
     }
     }
    #endregion
    #region Obtención de datos
    //Obtencion de datos
    /// <summary>
    /// Obtiene todos los datos de la tabla Apu_Estructura_Varios
    /// </summary> 
    /// <returns>Lista de objetos Apu_Estructura_Varios</returns> 
    public List <Apu_Estructura_Varios> Get ( Scope s )
    {
    string llamada = "";
    List <Apu_Estructura_Varios> lista= new List <Apu_Estructura_Varios> ();
    //Extrae los datos
    if(s != null)
    {
    Proyectos.Apu_Estructura_VariosDataTable tabla = 
    Adapter.Get (s.Ver_Version_Id);
    //Cuenta  el número  de registros de la tabla
    int numeroRegistros = tabla.Count;
    llamada = "Nombre del Método Utilizado: Get "  + "Parametros  Enviados en el Método: s "  + " Nombre del Store Procedure: " + " Apu_Estructura_Varios_Get "+ " Número de Registros: " + numeroRegistros;
    //Carga en la lista
      foreach (Proyectos.Apu_Estructura_VariosRow fila in tabla)
      lista.Add(new Apu_Estructura_Varios(
      
    fila.Id,
    fila.Codigo,
    fila.Estado,
    fila.Apu_Estructura_Id,
    fila.Apu_Varios_Id,
    fila.Cantidad,
    fila.Int_Moneda_Id,
    fila.Int_Moneda_Simbolo,
    fila.Apu_Varios_Codigo,
    fila.Apu_Varios_Nombre,
    fila.Apu_Varios_Tipo,
    fila.Apu_Varios_Costo_Parcial,
    fila.Apu_Varios_Costo_Otros,
    fila.Apu_Estructura_Codigo,
    fila.Apu_Estructura_Nombre,
    fila.Apu_Varios_Costo,
    fila.Costo_x_Cantidad,
    fila.Tipo_Nombre,
    fila.Estado_Nombre));
      }
      //Devuleve la Lista
      return lista;
      }
      public List <Apu_Estructura_Varios> GetByCodigo( Scope s , string Codigo)
          {
          string llamada = "";
          List <Apu_Estructura_Varios> lista= new List <Apu_Estructura_Varios> ();
          //Extrae los datos
          if(s != null)
          {
          Proyectos.Apu_Estructura_VariosDataTable tabla = 
          Adapter.GetByCodigo(s.Ver_Version_Id, Codigo);
          //Cuenta  el número  de registros de la tabla
          int numeroRegistros = tabla.Count;
          llamada = "Nombre del Método Utilizado: " + " GetByCodigo" + " Parametros  Enviados en el Método: "+ "," + " s.Ver_Version_Id : " + s.Ver_Version_Id+ "," + " Codigo : " + Codigo  + " Nombre del Store Procedure: " + "dbo.Apu_Estructura_Varios_ByCodigo " + " Número de Registros: " + numeroRegistros;
          //Carga en la lista
          foreach (Proyectos.Apu_Estructura_VariosRow fila in tabla)
          lista.Add(new Apu_Estructura_Varios(
          
    fila.Id,
    fila.Codigo,
    fila.Estado,
    fila.Apu_Estructura_Id,
    fila.Apu_Varios_Id,
    fila.Cantidad,
    fila.Int_Moneda_Id,
    fila.Int_Moneda_Simbolo,
    fila.Apu_Varios_Codigo,
    fila.Apu_Varios_Nombre,
    fila.Apu_Varios_Tipo,
    fila.Apu_Varios_Costo_Parcial,
    fila.Apu_Varios_Costo_Otros,
    fila.Apu_Estructura_Codigo,
    fila.Apu_Estructura_Nombre,
    fila.Apu_Varios_Costo,
    fila.Costo_x_Cantidad,
    fila.Tipo_Nombre,
    fila.Estado_Nombre));
          }
          //Realiza la auditoria
          Auditar.Registro(s, llamada, lista, Textos._AUDITAR_ACCION_SELECT_SEL);
          //Devuleve la Lista
          return lista;
          }
          public List <Apu_Estructura_Varios> GetByEstructura( Scope s , string Apu_Estructura_Id)
          {
          string llamada = "";
          List <Apu_Estructura_Varios> lista= new List <Apu_Estructura_Varios> ();
          //Extrae los datos
          if(s != null)
          {
          Proyectos.Apu_Estructura_VariosDataTable tabla = 
          Adapter.GetByEstructura(s.Ver_Version_Id, Apu_Estructura_Id);
          //Cuenta  el número  de registros de la tabla
          int numeroRegistros = tabla.Count;
          llamada = "Nombre del Método Utilizado: " + " GetByEstructura" + " Parametros  Enviados en el Método: "+ "," + " s.Ver_Version_Id : " + s.Ver_Version_Id+ "," + " Apu_Estructura_Id : " + Apu_Estructura_Id  + " Nombre del Store Procedure: " + "dbo.Apu_Estructura_Varios_ByEstructura " + " Número de Registros: " + numeroRegistros;
          //Carga en la lista
          foreach (Proyectos.Apu_Estructura_VariosRow fila in tabla)
          lista.Add(new Apu_Estructura_Varios(
          
    fila.Id,
    fila.Codigo,
    fila.Estado,
    fila.Apu_Estructura_Id,
    fila.Apu_Varios_Id,
    fila.Cantidad,
    fila.Int_Moneda_Id,
    fila.Int_Moneda_Simbolo,
    fila.Apu_Varios_Codigo,
    fila.Apu_Varios_Nombre,
    fila.Apu_Varios_Tipo,
    fila.Apu_Varios_Costo_Parcial,
    fila.Apu_Varios_Costo_Otros,
    fila.Apu_Estructura_Codigo,
    fila.Apu_Estructura_Nombre,
    fila.Apu_Varios_Costo,
    fila.Costo_x_Cantidad,
    fila.Tipo_Nombre,
    fila.Estado_Nombre));
          }
          //Realiza la auditoria
          Auditar.Registro(s, llamada, lista, Textos._AUDITAR_ACCION_SELECT_SEL);
          //Devuleve la Lista
          return lista;
          }
          public List <Apu_Estructura_Varios> GetById( Scope s , string Id)
          {
          string llamada = "";
          List <Apu_Estructura_Varios> lista= new List <Apu_Estructura_Varios> ();
          //Extrae los datos
          if(s != null)
          {
          Proyectos.Apu_Estructura_VariosDataTable tabla = 
          Adapter.GetById(s.Ver_Version_Id, Id);
          //Cuenta  el número  de registros de la tabla
          int numeroRegistros = tabla.Count;
          llamada = "Nombre del Método Utilizado: " + " GetById" + " Parametros  Enviados en el Método: "+ "," + " s.Ver_Version_Id : " + s.Ver_Version_Id+ "," + " Id : " + Id  + " Nombre del Store Procedure: " + "dbo.Apu_Estructura_Varios_ById " + " Número de Registros: " + numeroRegistros;
          //Carga en la lista
          foreach (Proyectos.Apu_Estructura_VariosRow fila in tabla)
          lista.Add(new Apu_Estructura_Varios(
          
    fila.Id,
    fila.Codigo,
    fila.Estado,
    fila.Apu_Estructura_Id,
    fila.Apu_Varios_Id,
    fila.Cantidad,
    fila.Int_Moneda_Id,
    fila.Int_Moneda_Simbolo,
    fila.Apu_Varios_Codigo,
    fila.Apu_Varios_Nombre,
    fila.Apu_Varios_Tipo,
    fila.Apu_Varios_Costo_Parcial,
    fila.Apu_Varios_Costo_Otros,
    fila.Apu_Estructura_Codigo,
    fila.Apu_Estructura_Nombre,
    fila.Apu_Varios_Costo,
    fila.Costo_x_Cantidad,
    fila.Tipo_Nombre,
    fila.Estado_Nombre));
          }
          //Realiza la auditoria
          Auditar.Registro(s, llamada, lista, Textos._AUDITAR_ACCION_SELECT_SEL);
          //Devuleve la Lista
          return lista;
          }
          #endregion
    #region Operaciones con datos
    
    //Inserta
    /// <summary>
    /// Inserta el objeto en la tabla Apu_Estructura_Varios
    /// </summary>
    /// <param name="s">Variables de ámbito como la versión y la sucursal</param>
    // <returns></returns>
    public string Insert(Scope s, Apu_Estructura_Varios o)
    {
    // Genera un nuevo Id, codigo y estado.
    o.GenNewId(s.Int_Sucursal_Numero);
    o.GenCodigo(s.Ver_Version_Id);
    o.GenEstado();
    // Controla el error de clave primaria duplicada.
    try
    {
    Adapter.Insert(
    
          o.Id,
          o.Codigo,
          o.Apu_Estructura_Id,
          o.Apu_Varios_Id,
          o.Cantidad,
          o.Estado
    );
}
catch (SqlException e)
{
    Exception eCaso;
    Exception otroEX;
    switch (e.Number)
    {
        // Si el error es de violación PK, entonces repite.
        case 2627:
            string mensaje = e.Errors[0].Message;
            if (mensaje.StartsWith(
                   Textos._ERR_VIOLATION_UNIQUE_KEY)
                   )
                return Insert(s, o);
            else
            {
                if (e.Message.Contains(TXT_BDD._IX_Apu_Estructura_Varios_Codigo))
                {
                    eCaso = new Exception("");
                    otroEX = new Exception(TXT_Mensajes._MSJ32, eCaso);
                    throw (otroEX);
                }

                eCaso = new Exception(e.Message);
                otroEX = new Exception(TXT_Mensajes._MSJ34, eCaso);
                throw (otroEX);
            }
            break;
        default:
            eCaso = new Exception(e.Message);
            otroEX = new Exception(TXT_Mensajes._MSJ34, eCaso);
            throw (otroEX);
    }
}
    //Control de Auditoria
    Auditar.Registro(s, o, Textos._AUDITAR_ACCION_INSERT);
    //Retorna el Id Insetado
     return o.Id;
    }
    // Borra
    /// <summary>
    /// Borra el objeto de la tabla Apu_Estructura_Varios
    ///</summary>
     /// <param name="o">Objeto a actualizar</param>
    /// <returns></returns>
    public int Delete(Scope s,  Apu_Estructura_Varios o)
    {
    int resultado = 0;
            try
            {
           resultado = Adapter.Delete(
    
          o.Id,
          o.Codigo,
          o.Apu_Estructura_Id,
          o.Apu_Varios_Id,
          o.Cantidad,
          o.Estado
    );
       }
       catch (SqlException e)
       {
           Exception eCaso;
           Exception otroEX;

           eCaso = new Exception(e.Message);
           otroEX = new Exception(TXT_Mensajes._MSJ34, eCaso);
           throw (otroEX);
       }
    Auditar.Registro(s, o, Textos._AUDITAR_ACCION_DELETE);
    return resultado;
    }//Actualiza
    /// <summary>
    //Actualiza la tabla Apu_Estructura_Varios
    /// </summary>
    /// <param name="o">Objeto que contiene la información a actualizar</param>
    /// <param name="original">Original para concurrencia optimista</param> 
    /// <returns></returns>
    public int Update(Scope s, Apu_Estructura_Varios o, Apu_Estructura_Varios original)
    {
    int resultado = 0;
            try
            {
                resultado = Adapter.Update(
    
    
          o.Id,
          o.Codigo,
          o.Apu_Estructura_Id,
          o.Apu_Varios_Id,
          o.Cantidad,
          o.Estado,
          original.Id,
          original.Codigo,
          original.Apu_Estructura_Id,
          original.Apu_Varios_Id,
          original.Cantidad,
          original.Estado
    
    );
            }
            catch (SqlException e)
            {
                Exception eCaso;
                Exception otroEX;
                if (e.Message.Contains(TXT_BDD._IX_Apu_Estructura_Varios_Codigo))
                {
                    eCaso = new Exception("");
                    otroEX = new Exception(TXT_Mensajes._MSJ32, eCaso);
                    throw (otroEX);
                }

                eCaso = new Exception(e.Message);
                otroEX = new Exception(TXT_Mensajes._MSJ34, eCaso);
                throw (otroEX);
            }
    Auditar.Registro(s, o, Textos._AUDITAR_ACCION_UPDATE);
    return resultado;
    }
    #endregion
    }
    }
